package com.example.tests;

import java.io.File;
import java.io.FileReader;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Properties;
import java.util.logging.Logger;

import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Optional;
import org.testng.annotations.Parameters;

import com.example.fw.ApplicationManager;

public class TestBase {
	
	protected Logger log = Logger.getLogger("TEST");
	
	protected static ApplicationManager app;	
	
	@BeforeClass
	@Parameters ({"configFile"})
	public void setUp (@Optional String configFile) throws Exception {
		if(configFile == null) {
			configFile = System.getProperty("configFile");
		}
		if(configFile == null) {
			configFile = System.getenv("configFile");
		}
		if(configFile == null) {
			configFile = "application.properties";
		}
		Properties properties = new Properties();
		properties.load(new FileReader(new File(configFile)));
		log.info("setUp start");
		app = ApplicationManager.getInstance();
		app = setProperties(properties);
		app.getFtpHelper().installConfigWithoutCaptcha();
		log.info("setUp end");
	}

	private ApplicationManager setProperties(Properties properties) {
		// TODO Auto-generated method stub
		return null;
	}

	@AfterTest
	public void tearDown() throws Exception {
		log.info("tearDown start");
		ApplicationManager.getInstance().stop();
		log.info("tearDown end");	
	}

}
